草庐IT

java treeset 抛出 illegalArgumentException : key out of range

全部标签

c++ - 为什么 std::bad_cast 被 boost::locale 抛出?

我试图了解如何使用boost::locale来比较忽略大小写和变体的字符串。我直接尝试了Boost文档中的代码:http://www.boost.org/doc/libs/1_51_0/libs/locale/doc/html/collation.htmlboost::locale::generatorgen;std::localevLocale=gen("");std::wstringa=L"Façade",b=L"facade";//Followingwillthrowbad_castbooleq=std::use_facet>(vLocale).compare(boost::lo

C++ 目标用简单的语法 T.g 抛出错误

我正在尝试使用简单的语法T.g将Cpp输出到具有树语法的AST。找不到源代码中不存在的AST.stg。3.4和3.5rc1都出现同样的错误。感谢您的帮助。java-jar../../../antlr-3.5-rc-1-complete.jarT.gTWalker.gerror(10):internalerror:T.g:java.lang.IllegalArgumentException:Nosuchgroupfile:org/antlr/codegen/templates/Cpp/AST.stgorg.stringtemplate.v4.STGroupFile.(STGroupFil

c++ - 为什么在我的析构函数中抛出时总是得到 "terminate called after throwing an instance of..."?

我正在尝试编写一个单元测试来检测对我的类的lock()功能的无效使用。为此,我想使用析构函数并从那里抛出异常。不幸的是,g++没有捕获异常,而是决定调用std::terminate()。类有一个非常简化的版本:classA{public:A():f_lock(0){}~A(){if(f_lock)throwmy_exception("stilllocked");}lock(){++f_lock;}unlock(){--f_lock;}private:intf_lock;};有一个有效的测试:A*a=newA;a->lock();...a->unlock();deletea;我正在尝试编

c++ - std::vector 中的元素可以有抛出析构函数吗?

当我查看Container它列出了对cppreference的要求Destructible作为value_type的要求。这似乎暗示容器元素的析构函数可能不会抛出。我无法在C++14标准中找到对这一要求的引用(没有查看旧版本)。我唯一能找到的是value_type必须是Erasable这根本不意味着任何异常安全。所以我的问题是,std::vector中的元素可以有抛出析构函数吗?如果不是,标准中的哪个部分禁止它?P.S.:别担心,我不打算创建带有抛出析构函数的类型。我只是在编写一个符合标准的实现,并试图获得正确的异常安全性。 最佳答案

c++ - 我相信这是 clang 中的一个错误,与构造函数抛出的放置新表达式有关

当new-expression的形式为new(std::nothrow)C;时,问题就出现了其中C是其构造函数抛出的类名。请参阅下面的代码和liveexample使用g++:#includevoid*operatornew(std::size_tsize,conststd::nothrow_t&)noexcept{void*p;p=malloc(size);std::coutg++打印以下内容,它似乎是正确的:operatornew(std::nothrow)C()operatordelete(std::nothrow)0x13f9c20exceptionthrowninC(int)w

c++ - Boost Program_Options 抛出 "character conversion failed"

我在Ubuntu14.04上,使用CMake和CLion。我正在尝试使用程序选项,以下代码取自其文档中的示例:#include#includeintmain(intac,char*av[]){namespacepo=boost::program_options;usingnamespacestd;po::options_descriptiondesc("Allowedoptions");desc.add_options()("help","producehelpmessage")("compression",po::value(),"setcompressionlevel");po::

c++ - 在抛出 'std::invalid_argument' what() : stoi 实例后终止调用

stoi函数使程序崩溃并显示错误消息"****@****:~>g++-std=c++0xm1.cppstimulation.hstims.hTask.hexoskeleton.hARAIG_Sensors.hProfile.hARAIG_Sensors.h:1:9:warning:#pragmaonceinmainfile[enabledbydefault]Profile.h:1:9:warning:#pragmaonceinmainfile[enabledbydefault]*****@****:~>a.outStimulationConfig.csvTaskConfiguratio

c++ - 带有 nothrow 选项的 Operator new 仍然抛出异常

有这样的代码:#includeintmain(){for(;;){int*ptr=new(std::nothrow)int;if(ptr==0){std::cout然而,这个程序仍然抛出std::bac_alloc异常,尽管new是用std::nothrow参数调用的。该程序在VisualC++2010中编译,为什么会抛出异常?编辑:在Windows上从mingw使用g++,一切正常。 最佳答案 0必须格式化为"0"。这将占用几个字节;我敢打赌这就是原因。在std::bad_alloc::bad_alloc上放置一个断点,你就会知道

c++ - 可以将 gdb 设置为在任何抛出时中断吗?

这个问题在这里已经有了答案:RunanApplicationinGDBUntilanExceptionOccurs(4个答案)关闭8年前。我正在调试带有异常抛出和异常处理的代码。我希望gdb在抛出异常时立即中断,这样我就可以检查程序的状态和调用堆栈。抛出任何异常时如何让gdb中断?

c++ - 如何从 Boost Spirit 中的函数中抛出 expectation_failure?

在Boost::Spirit中,如何从绑定(bind)了Boost::Bind的函数中触发expectation_failure?背景:我解析了一个包含复杂条目的大文件。当一个条目与前一个条目不一致时,我想失败并抛出一个expectation_failure(包含正确的解析位置信息)。当我解析一个条目时,我绑定(bind)了一个函数来确定该条目是否与之前看到的不一致。我编了一个小玩具示例来说明这一点。在这里,我只是想在int不能被10整除时抛出一个expectation_failure:#include#include#include#include#includenamespaceq